package org.tuoren.official.domain;

import com.baomidou.mybatisplus.annotation.*;
import jakarta.validation.constraints.NotBlank;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.tuoren.common.core.validate.AddGroup;
import org.tuoren.common.core.validate.EditGroup;
import org.tuoren.common.mybatis.core.domain.BaseEntity;

import java.io.Serial;
import java.util.List;

/**
 * 产品信息对象 t_product
 *
 * @author wl
 * @date 2024-11-26
 */
@Data
@EqualsAndHashCode(callSuper = true)
@TableName("t_product")
public class Product extends BaseEntity {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     *
     */
    @TableId(value = "id")
    private Long id;

    /**
     * 产品名称
     */
    private String name;

    /**
     * 所属产品线
     */
    private Long typeId;

    /**
     * 一句话简介
     */
    private String summary;

    /**
     * 规格
     */
    private String spec;

    /**
     * 型号
     */
    private String model;

    /**
     * 产品介绍
     */
    private String describes;

    /**
     * 产品图片URL
     */
    private String photoUrl;

    /**
     * 删除标志（0代表存在 2代表删除）
     */
    @TableLogic
    private String delFlag;
    /**
     * 显示顺序
     */
    private Integer orderNum;
    /**
     * 所属科室，多个科室以逗号分隔
     */
    @NotBlank(message = "所属科室，多个科室以逗号分隔不能为空", groups = { AddGroup.class, EditGroup.class })
    private String departmentId;
    @TableField(exist = false)
    private List<String> departmentList;
}
